<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #box1 {
            width: 500px;
            height: 500px;
            background-color: red;
            display: flex;
        }

        #box2 {
            width: 300px;
            height: 300px;
            background-color: blue;
            margin: auto;
            display: flex;
        }

        #box3 {
            width: 100px;
            height: 100px;
            background-color: yellow;
            margin: auto;
        }
    </style>
</head>

<body>
    <!-- 
        事件流：描述的是从页面中接收事件的顺序

        DOM 事件流分为3个阶段：
         1.捕获阶段:父级接收点击事件，如果没有操作，往下传递
         2.目标阶段  当前操作元素
         3.冒泡阶段:从目标元素出发，向父级传递，没有任何绑定，继续向上传播
         
         //目前用的都是冒泡机制   btn.onclick=function(){}  ，只有冒泡机制

         // 没有冒泡的事件名字   onmouseenter   onmouseleave  onblur  onfoucs

         同一种事件
     -->
    <div id="box1">
        <div id="box2">
            <div id="box3"></div>
        </div>
    </div>
    <script>
        var box1 = document.querySelector('#box1')
        var box2 = document.querySelector('#box2')
        var box3 = document.querySelector('#box3')

        //1.加事件  同一种事件  比如都是click
        //捕获   第三个参数是true     默认是false
        // box1.addEventListener('click',function(){
        //      alert('box1')
        // },true);

        // box2.addEventListener('click',function(){
        //      alert('box2')
        // },true)

        // box3.addEventListener('click',function(){
        //      alert('box3')
        // },true)



        //冒泡   第三个参数是false 或者不写     默认是false
        box1.addEventListener('click', function () {
            alert('box1')
        }, false);

        box2.addEventListener('click', function () {
            alert('box2')
        }, false)

        box3.addEventListener('click', function () {
            alert('box3')
        }, false)
    </script>
</body>

</html>